package org.edu.modules.center.controller;

import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.github.xiaoymin.knife4j.annotations.ApiOperationSupport;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import java.util.Arrays;
import java.util.Map;
import javax.servlet.http.HttpServletRequest;
import org.apache.shiro.SecurityUtils;
import org.apache.shiro.subject.Subject;
import org.edu.common.api.vo.Result;
import org.edu.common.aspect.annotation.AutoLog;
import org.edu.common.system.base.controller.BaseController;
import org.edu.common.system.query.QueryGenerator;
import org.edu.common.system.vo.LoginUser;
import org.edu.modules.center.entity.VeTeachActionLog;
import org.edu.modules.center.service.IVeTeachActionLogService;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;

@Api(tags={" 教学行为日志"})
@RestController
@RequestMapping({"/center/veTeachActionLog"})
public class VeTeachActionLogController
        extends BaseController<VeTeachActionLog, IVeTeachActionLogService>
{
    private static final Logger log = LoggerFactory.getLogger(VeTeachActionLogController.class);
    @Autowired
    private IVeTeachActionLogService veTeachActionLogService;

    @AutoLog("教学行为日志-分页查询")
    @ApiOperation(value="分页查询", notes="教学行为日志-分页查询")
    @PostMapping({"/list"})
    public Result<?> queryPageList(VeTeachActionLog veTeachActionLog, @RequestParam(name="pageNo", defaultValue="1") Integer pageNo, @RequestParam(name="pageSize", defaultValue="10") Integer pageSize, HttpServletRequest req)
    {
        if (veTeachActionLog.getUserId().equals(Integer.valueOf(0)))
        {
            LoginUser sysUser = (LoginUser)SecurityUtils.getSubject().getPrincipal();
//            veTeachActionLog.setUserId(sysUser.getUserid());
        }
        QueryWrapper<VeTeachActionLog> queryWrapper = QueryGenerator.initQueryWrapper(veTeachActionLog, req.getParameterMap());
        Page<Map<String, Object>> page = new Page(pageNo.intValue(), pageSize.intValue());
        queryWrapper.setEntity(veTeachActionLog);
        IPage<Map<String, Object>> pageList = this.veTeachActionLogService.pageMaps(page, queryWrapper);
        return Result.OK(pageList);
    }

    @AutoLog("教学行为日志-通过id查询")
    @ApiOperation(value="通过id查询", notes="教学行为日志-通过id查询")
    @PostMapping({"/publicInfo/queryById"})
    @ApiOperationSupport(order=1)
    public Result<?> queryById(@RequestParam(name="id", required=true) String id)
    {
        VeTeachActionLog veTeachActionLog = (VeTeachActionLog)this.veTeachActionLogService.getById(id);
        if (veTeachActionLog == null) {
            return Result.error("未找到对应数据");
        }
        return Result.OK(veTeachActionLog);
    }

    @AutoLog(" 教学行为日志-新增信息")
    @ApiOperation(value="新增信息", notes=" 教学行为日志-新增信息")
    @PostMapping({"/add"})
    public Result<?> add(@RequestBody VeTeachActionLog veTeachActionLog)
    {
        this.veTeachActionLogService.save(veTeachActionLog);
        return Result.OK("添加成功！");
    }

    @AutoLog(" 教学行为日志-修改信息")
    @ApiOperation(value="修改信息", notes=" 教学行为日志-修改信息")
    @PostMapping({"/edit"})
    public Result<?> edit(@RequestBody VeTeachActionLog veTeachActionLog)
    {
        this.veTeachActionLogService.updateById(veTeachActionLog);
        return Result.OK("编辑成功!");
    }

    @AutoLog(" 教学行为日志-通过id删除")
    @ApiOperation(value="通过id删除", notes=" 教学行为日志-通过id删除")
    @PostMapping({"/delete"})
    public Result<?> delete(@RequestParam(name="id", required=true) String id)
    {
        this.veTeachActionLogService.removeById(id);
        return Result.OK("删除成功!");
    }

    @AutoLog(" 教学行为日志-批量删除")
    @ApiOperation(value="批量删除", notes=" 教学行为日志-批量删除")
    @PostMapping({"/deleteBatch"})
    public Result<?> deleteBatch(@RequestParam(name="ids", required=true) String ids)
    {
        this.veTeachActionLogService.removeByIds(Arrays.asList(ids.split(",")));
        return Result.OK("批量删除成功!");
    }
}
